home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus 1995 #5 & #6 / Amiga Plus CD - 1995 - No. 5 and 6.iso / tex / mf / inputs / dc / dxitalp.mf < prev    next >
Text File  |  1994-04-12  |  4KB  |  87 lines

  1. % This is DXITALP.MF in text format, as of March 24, 1992
  2. %
  3. % DC fonts Version 1.1 (prerelease of EC fonts)
  4. %
  5. %          [ heavily borrowed from the Computer Modern Roman family of
  6. %            fonts by D. E. Knuth ]
  7. %
  8. % Content:
  9. %
  10. % italic special characters  &, ?, spanish ? which are
  11. %  different from roman
  12. %
  13. dcchar "Italic ampersand";
  14. beginchar("&",14u#,asc_height#,0);
  15. italcorr asc_height#*slant-1.5u#;
  16. adjust_fit(if monospace:-u#,-2u# else: 0,0 fi); pickup fine.nib;
  17. pos1(flare,0); pos2(hair,0); pos3(vair,90);
  18. rt x2r=hround.5w; x3=1/3(w-u);
  19. top y3r=h+o; y2=.5[x_height,h]; bulb(3,2,1);  % left bulb
  20. pos4(stem,180); pos5(vair,270); pos6(hair,360); pos7(vair,450);
  21. pos8(curve,540); pos9(vair,630); pos10(hair,720);
  22. lft x4r=hround 1.25u; x5=x7=x3+1/6u; rt x6r=hround(x5+1.5u);
  23. lft x8r=hround u; x9=.5w; rt x10r=hround(w-1.5u);
  24. y4=.5[y3,y5]; top y5l=vround .77x_height; y6=.5[y5,y7];
  25. y7l=good.y 1/3[y5,y3]; y8=.5[y7,y9]; bot y9r=-o; y10=bar_height;
  26. pos12(hair,0); pos13(curve,0); pos14(hair,0); pos15(vair,90); pos16(curve,90);
  27. rt x12r=rt x13r=hround(w-2u); lft x14l=hround(.5w+.5u);
  28. x15=x16=rt x14r+u;
  29. y12=y13=h-.5curve; y14=.5[bar_height,x_height];
  30. bot y15l=bot y16l=vround y10;
  31. numeric theta; theta=angle((z12-z14)xscaled 2);
  32. pos11(hair,theta); x11=w-4u; y11=.5[y13,y16];
  33. filldraw stroke pulled_arc.e(3,4) & pulled_arc.e(4,5) & pulled_arc.e(5,6)
  34.  & pulled_arc.e(6,7) & pulled_arc.e(7,8) & pulled_arc.e(8,9)
  35.  & {{interim superness:=more_super; pulled_arc.e(9,10)}}
  36.  ..tension .9 and 1..{dir(theta+100)}z11e;  % bowls, loop, and stem
  37. pos11'(hair,theta-90); z11'=z11;
  38. forsuffixes $=l,r: path p$;
  39.  p$=z12${down}..z11'${-dir theta}..{down}z14$...{right}z15$; endfor
  40. filldraw p.l--reverse p.r--cycle;  % arms
  41. path q[]; q1=z13r{up}..z13l{down}..cycle;
  42. q2=z16l{right}..z16r{left}..cycle;
  43. filldraw subpath(0,ypart(p.l intersectiontimes q1)) of q1--cycle; % upper bulb
  44. filldraw subpath(0,ypart(p.r intersectiontimes q2)) of q2--cycle; % lower bulb
  45. penlabels(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16); endchar;
  46.  
  47. dcchar "Italic question mark";
  48. beginchar("?",9u#,asc_height#,0);
  49. italcorr asc_height#*slant-u#;
  50. adjust_fit(0,0); pickup tiny.nib; pos10(dot_size,0); pos11(dot_size,90);
  51. lft x10l=hround(.5w-.5dot_size); bot y11l=0; z10=z11; dot(10,11);  % dot
  52. pickup fine.nib; pos1(flare,180); pos2(hair,180); pos3(vair,90);
  53. lft x1r=hround u; x3=.5w;
  54. y1-.5flare=x_height; top y3r=h+o; bulb(3,2,1); % bulb
  55. pos8(vair,-90); x8=.5w; bot y8r=.25[top y11r,x_height]+1;
  56. numeric theta; theta=90+angle(10u,y3-y8); slope:=(y3-y8)/10u;
  57. pos3'(vair,-90); z3'=z3; pos0(vstem,theta); x0=x3; y0=1/3[y8,y3];
  58. rt x4l=hround(w-1.5u); lft x7r=hround 1/3w;
  59. x4l-x4r=x7l-x7r=hround .5[vair,vstem]-fine;
  60. ellipse_set(3'l,4l,5l,0l); ellipse_set(3'r,4r,5r,0r); y4=y4r;
  61. ellipse_set(8l,7l,6l,0l); ellipse_set(8r,7r,6r,0r); y7=y7r;
  62. pos9(hair,0); rt x9r=hround(2/3w+.5hair); y9=good.y .5[y8,y0];
  63. filldraw stroke super_arc.e(3',4) & z4e{down}
  64.  ..z5e---z6e..z7e{down} & super_arc.e(7,8)...{up}z9e;  % main stroke
  65. penlabels(0,1,2,3,4,5,6,7,8,9,10,11); endchar;
  66.  
  67. dcchar "Spanish open italic question mark";
  68. beginchar(oct"276",9u#,asc_height#-desc_depth#,desc_depth#);
  69. adjust_fit(0,0); pickup tiny.nib; pos10(dot_size,0); pos11(dot_size,90);
  70. lft x10l=hround(.5w-.5dot_size); top y11r=h; z10=z11; dot(10,11);  % dot
  71. pickup fine.nib; pos1(flare,0); pos2(hair,0); pos3(vair,-90);
  72. rt x1r=hround(w-u); x3=.5w; y1+.5flare=asc_height-x_height-d;
  73. bot y3r=-d-o; bulb(3,2,1); % bulb
  74. pos8(vair,90); x8=.5w; top y8r=.25[bot y11l,y1+.5flare]-1;
  75. numeric theta; theta=angle(10u,y8-y3)-90; slope:=(y8-y3)/10u;
  76. pos3'(vair,90); z3'=z3; pos0(vstem,theta); x0=x3; y0=1/3[y8,y3];
  77. lft x4l=hround 1.5u; rt x7r=hround 2/3w;
  78. x4r-x4l=x7r-x7l=hround .5[vair,vstem]-fine;
  79. ellipse_set(3'l,4l,5l,0l); ellipse_set(3'r,4r,5r,0r); y4=y4r;
  80. ellipse_set(8l,7l,6l,0l); ellipse_set(8r,7r,6r,0r); y7=y7r;
  81. pos9(hair,180); lft x9r=hround(1/3w-.5hair); y9=good.y .5[y8,y0];
  82. filldraw stroke super_arc.e(3',4) & z4e{up}
  83.  ..z5e---z6e..z7e{up} & super_arc.e(7,8)...{down}z9e;  % main stroke
  84. penlabels(0,1,2,3,4,5,6,7,8,9,10,11); endchar;
  85.  
  86. endinput;
  87.